package cn.itcast.crm.dao;

import java.util.List;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;

import cn.itcast.crm.domain.Customer;

public interface CustomerRepository extends JpaRepository<Customer, Integer>, JpaSpecificationExecutor<Customer> {
	public List<Customer> findByFixedAreaIdIsNull();

	public List<Customer> findByFixedAreaId(String fixedAreaId);
	
	@Query("update Customer set fixedAreaId=? where id=?")
	@Modifying
	public void updateFixedAreaId(String fixedAreaId, Integer id);
	
	@Query("update Customer set fixedAreaId=null where fixedAreaId=?")
	@Modifying
	public void clearAssociationCustomers(String fixedAreaId);

	public Customer findByTelephone(String telephone);
	
	@Query("update Customer set type=1 where telephone=?")
	@Modifying
	public void updateCustomerType(String telephone);

	public Customer findByTelephoneAndPassword(String telephone, String password);

	@Query("select fixedAreaId from Customer where address=?")
	public String findFixedAreaIdByAddress(String address);

}
